package com.order.mapper;

import com.order.entity.SysUser;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;

import java.util.List;

/**
 * 用户Mapper接口
 */
@Mapper
public interface SysUserMapper {

    /**
     * 根据ID查询用户
     */
    SysUser findById(@Param("id") Long id);

    /**
     * 根据用户名查询用户
     */
    SysUser findByUsername(@Param("username") String username);

    /**
     * 插入用户
     */
    int insert(SysUser user);

    /**
     * 更新用户
     */
    int update(SysUser user);

    /**
     * 删除用户
     */
    int deleteById(@Param("id") Long id);

    /**
     * 分页查询用户列表
     */
    List<SysUser> findPage(@Param("offset") Integer offset, 
                          @Param("pageSize") Integer pageSize,
                          @Param("keyword") String keyword,
                          @Param("roleType") Integer roleType);

    /**
     * 统计用户数量
     */
    Long countUsers(@Param("keyword") String keyword, 
                   @Param("roleType") Integer roleType);

    /**
     * 根据角色类型查询用户列表
     */
    List<SysUser> findByRoleType(@Param("roleType") Integer roleType);
}